/* drivers/input/touchscreen/gt9xx.h
 *
 * 2010 - 2013 Goodix Technology.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be a reference
 * to you, when you are integrating the GOODiX's CTP IC into your system,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 */

#ifndef _GOODIX_GT9XX_H_
#define _GOODIX_GT9XX_H_

#include <linux/kernel.h>
#include <linux/hrtimer.h>
#include <linux/i2c.h>
#include <linux/input.h>
#include <linux/module.h>
#include <linux/delay.h>
#include <linux/i2c.h>
#include <linux/proc_fs.h>
#include <linux/string.h>
#include <linux/uaccess.h>
#include <linux/vmalloc.h>
#include <linux/interrupt.h>
#include <linux/io.h>
#include <linux/slab.h>

#ifdef CONFIG_HAS_EARLYSUSPEND
#include <linux/earlysuspend.h>
#endif
#include <linux/gpio.h>
#include "../../init-input.h"
#include <linux/pinctrl/consumer.h>
#include <linux/pinctrl/pinctrl-sunxi.h>

/***************************PART1:ON/OFF define*******************************/
#define GTP_CUSTOM_CFG        0
#define GTP_CHANGE_X2Y        0
#define GTP_DRIVER_SEND_CFG   0
#define GTP_HAVE_TOUCH_KEY    0
#define GTP_ICS_SLOT_REPORT   0

#define GTP_AUTO_UPDATE       0    /* auto update fw by .bin file as default*/
#define GTP_HEADER_FW_UPDATE  1    /* auto update fw by gtp_default_FW in gt9xx_firmware.h, function together with GTP_AUTO_UPDATE */
#define GTP_AUTO_UPDATE_CFG   0    /* auto update config by .cfg file, function together with GTP_AUTO_UPDATE*/

#define GTP_COMPATIBLE_MODE   0    /* compatible with GT9XXF*/

#define GTP_CREATE_WR_NODE    1
#define GTP_ESD_PROTECT       0    /* esd protection with a cycle of 2 seconds*/

#define GTP_WITH_PEN          0
#define GTP_PEN_HAVE_BUTTON   0    /* active pen has buttons, function together with GTP_WITH_PEN*/

#define GTP_DEBUG_ON          0
#define GTP_INFO_ON           0
#define GTP_DEBUG_ARRAY_ON    0
#define GTP_DEBUG_FUNC_ON     0
#define GTP_I2C_TEST          1

#if GTP_COMPATIBLE_MODE
typedef enum {
	CHIP_TYPE_GT9  = 0,
	CHIP_TYPE_GT9F = 1,
} CHIP_TYPE_T;
#endif

struct goodix_ts_data {
	spinlock_t irq_lock;
	struct i2c_client *client;
	struct input_dev  *input_dev;
	struct hrtimer timer;
	struct work_struct  work;
#ifdef CONFIG_HAS_EARLYSUSPEND
	struct early_suspend early_suspend;
#endif
	s32 irq_is_disable;
	s32 use_irq;
	u16 abs_x_max;
	u16 abs_y_max;
	u8  max_touch_num;
	u8  int_trigger_type;
	u8  green_wake_mode;
	u8  enter_update;
	u8  gtp_is_suspend;
	u8  gtp_rawdiff_mode;
	u8  gtp_cfg_len;
	u8  fixed_cfg;
	u8  fw_error;
	u8  pnl_init_error;
#if GTP_WITH_PEN
	struct input_dev *pen_dev;
#endif

#if GTP_ESD_PROTECT
	spinlock_t esd_lock;
	u8  esd_running;
	s32 clk_tick_cnt;
#endif

#if GTP_COMPATIBLE_MODE
	u16 bak_ref_len;
	s32 ref_chk_fs_times;
	s32 clk_chk_fs_times;
	CHIP_TYPE_T chip_type;
	u8 rqst_processing;
	u8 is_950;
#endif
};

extern u16 show_len;
extern u16 total_len;

extern struct ctp_config_info config_info;
extern void gtp_set_int_value(int status);
extern void gtp_set_io_int(void);
#define GTP_INT_PORT    		(config_info.irq_gpio.gpio)
#define GTP_RST_PORT    		(config_info.wakeup_gpio.gpio)
#define GTP_INT_IRQ     		(gpio_to_irq(GTP_INT_PORT))

/*******************************************************************************

#define GTP_GPIO_AS_INPUT(pin)          do{\
											long unsigned int	config; \
											char pin_name[8]; \
											sunxi_gpio_to_name(pin,pin_name); \
											config = SUNXI_PINCFG_PACK(SUNXI_PINCFG_TYPE_FUNC, 0xFFFF); \
											pin_config_get(SUNXI_PINCTRL,pin_name,&config); \
											if (1 != SUNXI_PINCFG_UNPACK_VALUE(config)){ \
													config = SUNXI_PINCFG_PACK(SUNXI_PINCFG_TYPE_FUNC,1); \
													pin_config_set(SUNXI_PINCTRL,pin_name,config); \
											} \
										}while(0)
#define GTP_GPIO_AS_INT(pin)            do{\
											long unsigned int	config; \
											char pin_name[8]; \
											sunxi_gpio_to_name(pin,pin_name); \
											config = SUNXI_PINCFG_PACK(SUNXI_PINCFG_TYPE_FUNC, 0xFFFF); \
											pin_config_get(SUNXI_PINCTRL,pin_name,&config); \
											if (4 != SUNXI_PINCFG_UNPACK_VALUE(config)){ \
												config = SUNXI_PINCFG_PACK(SUNXI_PINCFG_TYPE_FUNC,4); \
												pin_config_set(SUNXI_PINCTRL,pin_name,config); \
											} \
										}while(0)
#define GTP_GPIO_GET_VALUE(pin)         gpio_get_value(pin)
#define GTP_GPIO_OUTPUT(pin,level)      gpio_direction_output(pin,level)
#define GTP_GPIO_REQUEST(pin, label)    gpio_request(pin, label)
#define GTP_GPIO_FREE(pin)              gpio_free(pin)
#define GTP_IRQ_TAB                     {IRQ_TYPE_EDGE_RISING, IRQ_TYPE_EDGE_FALLING, IRQ_TYPE_LEVEL_LOW, IRQ_TYPE_LEVEL_HIGH}

********************************************************************************/

/*************************** PART2:TODO define **********************************
 STEP_1(REQUIRED): Define Configuration Information Group(s)
 Sensor_ID Map:
 sensor_opt1 sensor_opt2 Sensor_ID
    GND         GND         0
    VDDIO       GND         1
    NC          GND         2
    GND         NC/300K     3
    VDDIO       NC/300K     4
    NC          NC/300K     5

 TODO: define your own default or for Sensor_ID == 0 config here.
 The predefined one is just a sample config, which is not suitable for your tp in most cases.
 suozhi,1536*2048,gt9271,COF
************************************************************************************/
#define CTP_CFG_GROUP1 {\
	0x46, 0x80, 0x07, 0xB0, 0x04, 0x0A, 0x3D, 0x00, 0x01, 0x0A,\
	0x1E, 0x0F, 0x50, 0x3C, 0x03, 0x04, 0x01, 0x01, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x1A, 0x1C, 0x1E, 0x14, 0x90, 0x30, 0xAA,\
	0x32, 0x30, 0x03, 0x15, 0x00, 0x00, 0x02, 0x03, 0x03, 0x1D,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0x00,\
	0x00, 0x27, 0x3B, 0x94, 0xC5, 0x02, 0x08, 0x00, 0x00, 0x04,\
	0x8C, 0x28, 0x00, 0x85, 0x2C, 0x00, 0x80, 0x30, 0x00, 0x7B,\
	0x34, 0x00, 0x77, 0x38, 0x00, 0x77, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x19, 0x18, 0x17, 0x16, 0x15, 0x14, 0x11, 0x10,\
	0x0F, 0x0E, 0x0D, 0x0C, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04,\
	0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x02, 0x04, 0x06, 0x07, 0x08, 0x0A, 0x0C,\
	0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x2A, 0x29,\
	0x28, 0x27, 0x26, 0x25, 0x24, 0x23, 0x22, 0x21, 0x20, 0x1F,\
	0x1E, 0x1C, 0x1B, 0x19, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x61, 0x01}


/* TODO: define your config for Sensor_ID == 1 here, if needed*/
/* for yuxin gt9110,COB*/
#define CTP_CFG_GROUP2 {\
	0x41, 0x00, 0x06, 0x00, 0x08, 0x0A, 0xC5, 0x00, 0x01, 0x08,\
	0x28, 0x05, 0x50, 0x32, 0x03, 0x05, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x95, 0x35, 0xFF,\
	0x1E, 0x20, 0x31, 0x0D, 0x00, 0x00, 0x00, 0x1A, 0x03, 0x2D,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x0F, 0x4B, 0x94, 0xC5, 0x02, 0x08, 0x00, 0x00, 0x04,\
	0xD0, 0x11, 0x00, 0x9A, 0x18, 0x00, 0x76, 0x21, 0x00, 0x5C,\
	0x2E, 0x00, 0x4A, 0x40, 0x00, 0x4A, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x1D, 0x1C, 0x1B, 0x1A, 0x19, 0x18, 0x17, 0x16,\
	0x15, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0F, 0x0E, 0x0D, 0x0C,\
	0x0B, 0x0A, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04, 0x03, 0x02,\
	0x01, 0x00, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0F, 0x0E, 0x0D,\
	0x0C, 0x0B, 0x0A, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04, 0x03,\
	0x02, 0x01, 0x00, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1B, 0x1C,\
	0x1D, 0x1E, 0x1F, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26,\
	0x27, 0x28, 0x29, 0x2A, 0x2A, 0x01}


/* TODO: define your config for Sensor_ID == 2 here, if needed*/
/*for yuxin gt9271,COF*/
#define CTP_CFG_GROUP3 {\
	0x41, 0x00, 0x06, 0x00, 0x08, 0x0A, 0x05, 0x00, 0x01, 0x0F,\
	0x28, 0x0F, 0x50, 0x32, 0x03, 0x05, 0x00, 0x00, 0xFB, 0x03,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x90, 0x30, 0xAA,\
	0x1F, 0x1C, 0xD6, 0x09, 0x00, 0x00, 0x00, 0x9A, 0x33, 0x25,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x19,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x01, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09,\
	0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x14, 0x15, 0x16, 0x17,\
	0x18, 0x19, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0F, 0x0E, 0x0D,\
	0x0C, 0x0A, 0x08, 0x07, 0x06, 0x04, 0x02, 0x00, 0x19, 0x1B,\
	0x1C, 0x1E, 0x1F, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26,\
	0x27, 0x28, 0x29, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x63, 0x01}

/* TODO: define your config for Sensor_ID == 3 here, if needed*/
/*for dushulang gt9110,COF*/
#define CTP_CFG_GROUP4 {\
	0x41, 0x56, 0x05, 0x00, 0x03, 0x0A, 0x3D, 0x00, 0x01, 0x08,\
	0x28, 0x08, 0x50, 0x32, 0x03, 0x07, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x19, 0x1A, 0x1E, 0x14, 0x95, 0x35, 0xFF,\
	0x2A, 0x2C, 0x39, 0x13, 0x00, 0x00, 0x00, 0x9A, 0x03, 0x2D,\
	0x00, 0x00, 0x00, 0x80, 0x83, 0x04, 0x6E, 0x64, 0x14, 0x00,\
	0x00, 0x1E, 0x3C, 0x94, 0xC5, 0x02, 0x07, 0x00, 0x00, 0x04,\
	0x96, 0x20, 0x00, 0x89, 0x25, 0x00, 0x7F, 0x2A, 0x00, 0x77,\
	0x30, 0x00, 0x6F, 0x38, 0x00, 0x6F, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,\
	0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11,\
	0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B,\
	0x1C, 0x1D, 0x2A, 0x29, 0x28, 0x27, 0x26, 0x25, 0x24, 0x23,\
	0x22, 0x21, 0x20, 0x1F, 0x1E, 0x1D, 0x1C, 0x1B, 0x19, 0x18,\
	0x17, 0x16, 0x15, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0F, 0x0E,\
	0x0D, 0x0C, 0x0B, 0x0A, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04,\
	0x03, 0x02, 0x01, 0x00, 0x24, 0x01}
/* TODO: define your config for Sensor_ID == 4 here, if needed*/
/* machine: noah*/
#define CTP_CFG_GROUP5 {\
	0x46, 0x00, 0x05, 0x20, 0x03, 0x0A, 0x3D, 0x00, 0x01, 0x0A,\
	0x1E, 0x0F, 0x50, 0x3C, 0x03, 0x04, 0x01, 0x01, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x1A, 0x1C, 0x1E, 0x14, 0x90, 0x30, 0xAA,\
	0x32, 0x30, 0x03, 0x15, 0x00, 0x00, 0x02, 0x03, 0x03, 0x1D,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x27, 0x3B, 0x94, 0xC5, 0x02, 0x08, 0x00, 0x00, 0x04,\
	0x8C, 0x28, 0x00, 0x85, 0x2C, 0x00, 0x80, 0x30, 0x00, 0x7B,\
	0x34, 0x00, 0x77, 0x38, 0x00, 0x77, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x01, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09,\
	0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x14, 0x15, 0x16, 0x17,\
	0x18, 0x19, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x2A, 0x29, 0x28, 0x27, 0x26, 0x25, 0x24, 0x23,\
	0x22, 0x21, 0x20, 0x1F, 0x1E, 0x1C, 0x1B, 0x19, 0x14, 0x13,\
	0x12, 0x11, 0x10, 0x0F, 0x0E, 0x0D, 0x0C, 0x0A, 0x08, 0x07,\
	0x06, 0x04, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x7B, 0x01}


/* TODO: define your config for Sensor_ID == 5 here, if needed*/
#define CTP_CFG_GROUP6 {\
	0x41, 0x00, 0x06, 0x00, 0x08, 0x0A, 0x35, 0x00, 0x01, 0x0A,\
	0x28, 0x0A, 0x50, 0x32, 0x03, 0x03, 0x00, 0x00, 0xFF, 0x7F,\
	0x00, 0x00, 0x04, 0x16, 0x1A, 0x1E, 0x14, 0x90, 0x30, 0xAA,\
	0x30, 0x32, 0x2E, 0x0B, 0x00, 0x00, 0x00, 0x9A, 0x33, 0x45,\
	0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x23, 0x1E, 0x41, 0x4F, 0xC5, 0x01, 0x08, 0x00, 0x00, 0x04,\
	0xC1, 0x20, 0x00, 0xAD, 0x25, 0x00, 0x99, 0x2C, 0x00, 0x8B,\
	0x33, 0x00, 0x7E, 0x3C, 0x00, 0x7E, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x19,\
	0x50, 0x37, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x01, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09,\
	0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x14, 0x15, 0x16, 0x17,\
	0x18, 0x19, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x2A, 0x29, 0x28, 0x27, 0x26, 0x25, 0x24, 0x23,\
	0x22, 0x21, 0x20, 0x1F, 0x1E, 0x1C, 0x1B, 0x19, 0x14, 0x13,\
	0x12, 0x11, 0x10, 0x0F, 0x0E, 0x0D, 0x0C, 0x0A, 0x08, 0x07,\
	0x06, 0x04, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x21, 0x01}

/*1680 * 480*/
#define CTP_CFG_GROUP7 {\
	0x42, 0x40, 0x06, 0xE0, 0x01, 0x0A, 0x0D, 0x00, 0x01, 0x08,\
	0x28, 0x05, 0x50, 0x32, 0x03, 0x05, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x8C, 0x2D, 0x08,\
	0x17, 0x15, 0x31, 0x0D, 0x00, 0x00, 0x01, 0xB9, 0x04, 0x1D,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x64, 0x32, 0x00, 0x00,\
	0x00, 0x0F, 0x23, 0x94, 0xC5, 0x02, 0x07, 0x00, 0x00, 0x04,\
	0x9E, 0x10, 0x00, 0x8A, 0x13, 0x00, 0x7C, 0x16, 0x00, 0x6B,\
	0x1B, 0x00, 0x60, 0x20, 0x00, 0x60, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x02, 0x04, 0x06, 0x08, 0x0A, 0x0C, 0x0E, 0x10,\
	0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x02, 0x04, 0x06, 0x08, 0x0A, 0x0C, 0x0F,\
	0x10, 0x12, 0x13, 0x14, 0x16, 0x18, 0x1C, 0x1D, 0x1E, 0x1F,\
	0x20, 0x21, 0x22, 0x24, 0x26, 0x28, 0x29, 0xFF, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0xE1, 0x01}

/* 400 * 1280*/
#define CTP_CFG_GROUP8 {\
	0x9A, 0x90, 0x01, 0x00, 0x05, 0x0A, 0x35, 0x00, 0x01, 0x0F,\
	0x28, 0x0F, 0x50, 0x32, 0x03, 0x05, 0x00, 0x41, 0x00, 0x00,\
	0x00, 0x00, 0x04, 0x16, 0x1C, 0x1E, 0x14, 0x8B, 0x2B, 0x0B,\
	0x28, 0x26, 0x0C, 0x08, 0x00, 0x00, 0x01, 0x9C, 0x03, 0x25,\
	0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x64, 0x32, 0x00, 0x00,\
	0x00, 0x19, 0x50, 0x94, 0xC5, 0x02, 0x07, 0x00, 0x00, 0x04,\
	0x8D, 0x13, 0x00, 0x5F, 0x1D, 0x00, 0x3E, 0x2E, 0x00, 0x2B,\
	0x48, 0x00, 0x20, 0x70, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x16, 0x14, 0x12, 0x10, 0x0E, 0x0C, 0x0A, 0x08,\
	0x06, 0x04, 0x02, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x13, 0x12, 0x10, 0x0F, 0x0C, 0x0A, 0x08, 0x06,\
	0x04, 0x02, 0x00, 0x16, 0x18, 0x1C, 0x1D, 0x1E, 0x1F, 0x20,\
	0x21, 0x22, 0x24, 0x26, 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\
	0x00, 0x00, 0x00, 0x00, 0xDF, 0x01}

#if GTP_CUSTOM_CFG
#define GTP_MAX_HEIGHT   800
#define GTP_MAX_WIDTH    480
#define GTP_INT_TRIGGER  0            /* 0: Rising 1: Falling*/
#else
#define GTP_MAX_HEIGHT   4096
#define GTP_MAX_WIDTH    4096
#define GTP_INT_TRIGGER  1
#endif
#define GTP_MAX_TOUCH         10

/* STEP_4(optional): If keys are available and reported as keys, config your key info here*/
#if GTP_HAVE_TOUCH_KEY
#define GTP_KEY_TAB  {KEY_MENU, KEY_HOME, KEY_BACK}
#endif

/***************************PART3:OTHER define**********************************/
#define GTP_DRIVER_VERSION          "V2.2<2014/01/14>"
#define GTP_I2C_NAME                "Goodix-TS"
#define GT91XX_CONFIG_PROC_FILE     "gt9xx_config"
#define GTP_POLL_TIME         10
#define GTP_ADDR_LENGTH       2
#define GTP_CONFIG_MIN_LENGTH 186
#define GTP_CONFIG_MAX_LENGTH 240
#define FAIL                  0
#define SUCCESS               1
#define SWITCH_OFF            0
#define SWITCH_ON             1

/******************** For GT9XXF Start **********************/
#define GTP_REG_BAK_REF                 0x99D0
#define GTP_REG_MAIN_CLK                0x8020
#define GTP_REG_CHIP_TYPE               0x8000
#define GTP_REG_HAVE_KEY                0x804E
#define GTP_REG_MATRIX_DRVNUM           0x8069
#define GTP_REG_MATRIX_SENNUM           0x806A

#define GTP_FL_FW_BURN              0x00
#define GTP_FL_ESD_RECOVERY         0x01
#define GTP_FL_READ_REPAIR          0x02

#define GTP_BAK_REF_SEND                0
#define GTP_BAK_REF_STORE               1
#define CFG_LOC_DRVA_NUM                29
#define CFG_LOC_DRVB_NUM                30
#define CFG_LOC_SENS_NUM                31

#define GTP_CHK_FW_MAX                  40
#define GTP_CHK_FS_MNT_MAX              300
#define GTP_BAK_REF_PATH                "/data/gtp_ref.bin"
#define GTP_MAIN_CLK_PATH               "/data/gtp_clk.bin"
#define GTP_RQST_CONFIG                 0x01
#define GTP_RQST_BAK_REF                0x02
#define GTP_RQST_RESET                  0x03
#define GTP_RQST_MAIN_CLOCK             0x04
#define GTP_RQST_RESPONDED              0x00
#define GTP_RQST_IDLE                   0xFF

/******************** For GT9XXF End **********************/
/* Registers define*/
#define GTP_READ_COOR_ADDR    0x814E
#define GTP_REG_SLEEP         0x8040
#define GTP_REG_SENSOR_ID     0x814A
#define GTP_REG_CONFIG_DATA   0x8047
#define GTP_REG_VERSION       0x8140

#define RESOLUTION_LOC        3
#define TRIGGER_LOC           8

#define CFG_GROUP_LEN(p_cfg_grp)  (sizeof(p_cfg_grp) / sizeof(p_cfg_grp[0]))
/* Log define*/
/***********************Add by zhongjian for sunxi tp************************
extern u32 debug_mask;

enum{
	DEBUG_INIT = 1U << 0,
	DEBUG_SUSPEND = 1U << 1,
	DEBUG_INT_INFO = 1U << 2,
	DEBUG_X_Y_INFO = 1U << 3,
	DEBUG_KEY_INFO = 1U << 4,
	DEBUG_WAKEUP_INFO = 1U << 5,
	DEBUG_OTHERS_INFO = 1U << 6,
};

#define dprintk(level_mask, fmt, arg...)	do {if (unlikely(debug_mask & level_mask)) \
		printk("***CTP***"fmt, ## arg); \
	} while (0)
***************************************************************************/

#define GTP_INFO(fmt, arg...) 			do {\
											if (GTP_INFO_ON) \
												printk("<<-GTP-INFO->> "fmt"\n", ##arg);\
										} while (0)
#define GTP_ERROR(fmt, arg...)          printk("<<-GTP-ERROR->> "fmt"\n", ##arg)
#define GTP_DEBUG(fmt, arg...)          do {\
											if (GTP_DEBUG_ON)\
											printk("<<-GTP-DEBUG->> [%u]"fmt"\n", __LINE__, ##arg);\
										} while (0)
#define GTP_DEBUG_ARRAY(array, num)    do {\
										s32 i;\
										u8 *a = array;\
										if (GTP_DEBUG_ARRAY_ON) {\
											printk("<<-GTP-DEBUG-ARRAY->>\n");\
											for (i = 0; i < (num); i++) {\
												printk("%02x   ", (a)[i]);\
												if ((i + 1) % 10 == 0) {\
													printk("\n");\
												} \
											} \
											printk("\n");\
										} \
										} while (0)
#define GTP_DEBUG_FUNC()               do {\
											if (GTP_DEBUG_FUNC_ON)\
											printk("<<-GTP-FUNC->> Func:%s@Line:%u\n", __func__, __LINE__);\
										} while (0)
#define GTP_SWAP(x, y)                 do {\
											typeof(x) z = x;\
											x = y;\
											y = z;\
										} while (0)

/*****************************End of Part III*********************************/

#endif /* _GOODIX_GT9XX_H_ */
